Linux日志切割方法[Logrotate、python、shell实现方式]
对于Linux系统安全来说,日志文件是极其重要的工具。不知为何,我发现很多运维同学的服务器上都运行着一些诸如每天切分Nginx日志之类的cron脚本,大家似乎遗忘了Logrotate,争相发明自己的轮子,这真是让人沮丧啊!就好比明明身边躺着现成的性感美女,大家却忙着自娱自乐,罪过!logrotate程序是一个日志文件管理工具。用于分割日志文件,删除旧的日志文件,并创建新的日志文件,起到“转储”作用。可以节省磁盘空间。下面就对logrotate日志轮转操作做一梳理记录。
1、什么是轮转?
日志轮循(轮转):日志轮转,切割,备份,归档
2、为什么需要轮转?
☆ 避免日志过大占满/var/log的文件系统
☆ 方便日志查看 ☆ 将丢弃系统中最旧的日志文件,以节省空间 ☆ 日志轮转的程序是logrotate
☆ logrotate本身不是系统守护进程,它是通过计划任务crond每天执行
3、安装与配置logrotate
1 | yum install logrotate -y |
3.1、配置文件介绍
Linux系统默认安装logrotate工具,它默认的配置文件在:
1 | /etc/logrotate.conf |
logrotate.conf 是主要的配置文件,logrotate.d 是一个目录,该目录里的所有文件都会被主动的读入/etc/logrotate.conf中执行。另外,如果 /etc/logrotate.d/ 里面的文件中没有设定一些细节,则会以/etc/logrotate.conf这个文件的设定来作为默认值。
logrotate是基于cron来运行的,其脚本是/etc/cron.daily/logrotate,日志轮转是系统自动完成的。实际运行时,Logrotate会调用配置文件/etc/logrotate.conf。可以在/etc/logrotate.d目录里放置自定义好的配置文件,用来覆盖Logrotate的缺省值。
1 | [root@huanqiu_web1 ~]# cat /etc/cron.daily/logrotate |
注意:如果等不及cron自动执行日志轮转,想手动强制切割日志,需要加 -f 参数;不过正式执行前最好通过Debug选项来验证一下(-d参数),这对调试也很重要!
1 | /usr/sbin/logrotate -f /etc/logrotate.d/nginx |
logrotate命令格式
1 | logrotate [OPTION...] <configfile> |
根据日志切割设置进行操作,并显示详细信息
1 | [root@huanqiu_web1 ~]# /usr/sbin/logrotate -v /etc/logrotate.conf |
根据日志切割设置进行执行,并显示详细信息,但是不进行具体操作,debug模式
1 | [root@huanqiu_web1 ~]# /usr/sbin/logrotate -d /etc/logrotate.conf |
查看各log文件的具体执行情况
1 | [root@fangfull_web1 ~]# cat /var/lib/logrotate.status |
3.2、logrotate配置文件
1 | vim /etc/logrotate.conf |
3.3、syslog 子配置文件
1 | [root@yunwei ~]# cat /etc/logrotate.d/syslog |
3.4、日志轮转常见参数
1 | 常用的指令解释,这些指令都可以在man logrotate 中找得到。 |
3.5、logrotate默认生效以及相关配置进行解释
1 | Logrotate是基于CRON来运行的,其脚本是/etc/cron.daily/logrotate, |
4、相关案例
4.1、logrotate实现Nginx日志切割
1 | [root@master-server ~]# vim /etc/logrotate.d/nginx |
4.2、shell脚本实现Nginx日志切割
1 | [root@bastion-IDC ~]# vim /usr/local/sbin/logrotate-nginx.sh |
crontab定时执行
1 | [root@bastion-IDC ~# crontab -e |
手动执行脚本
1 | [root@bastion-IDC ~]# /bin/bash -x /usr/local/sbin/logrotate-nginx.sh |
4.3、PHP日志切割
1 | [root@huanqiu_web1 ~]# cat /etc/logrotate.d/php |
4.4、linux系统日志切割
1 | [root@huanqiu_web1 ~]# cat /etc/logrotate.d/syslog |
4.5、Tomcat日志切割
1 | [root@huanqiu_web1 ~]# cat /etc/logrotate.d/syslog |
4.6、使用python脚本进行jumpserver日志切割
1 | [root@test-vm01 mnt]# cat log_rotate.py |
4.7、使用python脚本进行Nginx日志切割
1 | [root@test-vm01 mnt]# vim log_rotate.py |
5、logrotate无法自动轮询日志的解决办法
起始原因:使用logrotate轮询nginx日志,配置好之后,发现nginx日志连续两天没被切割,这是为什么呢??然后开始检查日志切割的配置文件是否有问题,检查后确定配置文件一切正常。于是怀疑是logrotate预定的cron没执行,查看了cron的日志,发现有一条”Dec 7 04:02:01 www crond[18959]: (root) CMD (run-parts /etc/cron.daily)”的日志,证明cron在04:02分时已经执行/etc/cron.daily目录下的程序。接着查看/etc /cron.daily/logrotate(这是logrotate自动轮转的脚本)的内容:
1 | [root@huanqiu_test ~]# cat /etc/cron.daily/logrotate |
有发现异常,配置好的日志轮转操作都是由这个脚本完成的,一切运行正常,脚本应该就没问题。 直接执行命令:
1 | [root@huanqiu_test ~]# /usr/sbin/logrotate /etc/logrotate.conf |
这些系统日志是正常轮询了,但nginx日志却还是没轮询,接着强行启动记录文件维护操作,纵使logrotate指令认为没有需要,应该有可能是logroate认为nginx日志太小,不进行轮询。 故需要强制轮询,即在/etc/cron.daily/logrotate脚本中将 -t 参数替换成 -f 参数
1 | [root@huanqiu_test ~]# cat /etc/cron.daily/logrotate |
重启下cron服务
1 | [root@huanqiu_test ~]# /etc/init.d/crond restart |